<template>
  <!--
使用说明：
1）、引入category-cascader.vue
2）、语法：<category-cascader :catelogPath.sync="catelogPath"></category-cascader>
    解释：
      catelogPath：指定的值是cascader初始化需要显示的值，应该和父组件的catelogPath绑定;
          由于有sync修饰符，所以cascader路径变化以后自动会修改父的catelogPath，这是结合子组件this.$emit("update:catelogPath",v);做的
      -->
  <div>
    <el-cascader
      v-model="paths"
      filterable
      clearable
      placeholder="试试搜索：手机"
      :options="categorys"
      :props="setting"
    />
  </div>
</template>

<script>
// 这里可以导入其他文件（比如：组件，工具js，第三方插件js，json文件，图片文件等等）
import { tree } from '@/api/product/category'
export default {
  // import引入的组件需要注入到对象中才能使用
  components: {},
  // 接受父组件传来的值
  props: {
    catelogPath: {
      type: Array,
      default() {
        return []
      }
    }
  },
  data() {
    // 这里存放数据
    return {
      setting: {
        value: 'catId',
        label: 'name',
        children: 'children'
      },
      categorys: [],
      paths: this.catelogPath
    }
  },
  watch: {
    catelogPath(v) {
      this.paths = this.catelogPath
    },
    paths(v) {
      // vue 自带的方法，子组件向父组件传值
      // this.$emit('update:catelogPath', v)
      // 还可以使用pubsub-js进行传值
      this.PubSub.publish('catPath', v)
    }
  },
  // 生命周期-创建完成（可以访问当前this实例）
  created() {
    this.getCategorys()
  },
  // 方法集合
  methods: {
    getCategorys() {
      tree().then(res => {
        this.categorys = res.data
      })

      // this.$http({
      //   url: this.$http.adornUrl('/product/category/list/tree'),
      //   method: 'get'
      // }).then(({ data }) => {
      //   this.categorys = data.data
      // })
    }
  }
}
</script>
<style scoped>
</style>
